草庐IT

java - MD5 哈希不同

全部标签

ruby - 如何通过数字索引获取哈希值

有一个散列:h={:a=>"val1",:b=>"val2",:c=>"val3"}我可以引用哈希值:h[:a],h[:c]但我想通过数字索引来引用:h[0]=>val1h[2]=>val3这可能吗? 最佳答案 h.values会给你一个请求的数组。>h.values#⇒[#[0]"val1",#[1]"val2",#[2]"val3"#]UPD虽然h[h.keys[0]]的答案被标记为正确,但我对基准测试有点好奇:h={:a=>"val1",:b=>"val2",:c=>"val3"}Benchmark.bmdo|x|x.repo

ruby-on-rails - 无差异访问的哈希

我有一个非Rails项目,我在其中从YAML文件加载一些设置:config=YAML::loadFile.open("#{LOG_ROOT}/config/database.yml")我只能像config["host"],config["username"]等访问这个hash我想要无差别访问,所以我可以同时使用:host和"host"。原因是,我要将此哈希传递给的项目中的一个gem似乎正在使用符号访问它,但目前失败了。在这种情况下,创建无差别访问的哈希的最佳方法是什么? 最佳答案 通过安装ActiveSupportgem,除了几kB

ruby - 什么是选项哈希?

有人能解释一下选项哈希吗?我正在学习testfirst.org的ruby类(class)。练习10(temperature_object)需要选项散列的知识。 最佳答案 Optionshash是ruby​​解析器的一个特性所支持的一个很好的概念。比如说,你有一个带有一些必需参数的方法。您也可以传递一些可选参数。随着时间的推移,您可能会添加更多可选参数或删除旧参数。为了保持方法声明的干净和稳定,您可以在散列中传递所有这些可选参数。这种方法看起来像这样:deffoo(arg1,arg2,opts={})opts.to_s#justret

ruby - 如何过滤哈希数组以仅获取另一个数组中的键?

我正在尝试为数组中的每个散列获取键的子集。哈希实际上要大得多,但我认为这更容易理解:[{id:2,start:"3:30",break:30,num_attendees:14},{id:3,start:"3:40",break:40,num_attendees:4},{id:4,start:"4:40",break:10,num_attendees:40}]我只想获取id和start值。我试过:return_keys=['id','start']return_array=events.select{|key,val|key.to_s.in?return_keys}但这会返回一个空数组。

ruby - 在 Ruby 中反转哈希

我如何反转散列中的元素,保持相同的值和键,但反转它们在散列中的顺序。像这样:{"4"=>"happiness","10"=>"cool","lala"=>"54","1"=>"spider"}并将其转换为:{"1"=>"spider","lala"=>"54","10"=>"cool","4"=>"happiness"}或者,也许我可以向后运行一个each循环,从散列中的最后一个元素开始,而不是从第一个元素开始? 最佳答案 您可以将哈希转换为数组,将其反转,然后再将其转换回哈希:reversed_h=Hash[h.to_a.reve

哈希键的 Ruby 值?

我有一个Ruby散列中的值列表。有没有办法检查key的值,如果它等于“X”,则执行“Y”?我可以使用hash.has_key?测试哈希是否有key,但现在我需要知道ifhash.key=="X"then...? 最佳答案 哈希使用方括号([])进行索引。就像数组一样。但是,哈希不是使用数字索引进行索引,而是使用您用于键的字符串文字或符号进行索引。所以如果你的散列类似于hash={"key1"=>"value1","key2"=>"value2"}您可以使用访问该值hash["key1"]或为了hash={:key1=>"value1

ruby - 哈希或其他对象的内存大小?

在Ruby1.9.3中以字节为单位获取给定散列(或任何对象)大小的最佳方法是什么?“FindnumberofbytesaparticularHashisusinginRuby”的解决方案在1.9.3中似乎无效,因为memsize_of不在ObjectSpace的文档中. 最佳答案 ObjectSpace.memsize_ofdoeswork在1.9.3中,记录与否:putsRUBY_VERSION#=>1.9.3require'objspace'pObjectSpace.memsize_of("a"*23)#=>23pObjectS

ruby - 在 Ruby 中,为什么 inspect() 会打印出某种与 object_id() 给出的不同的对象 ID?

p函数在打印出对象时,可能会给出一个ID,与object_id()给出的不同。不同数字的原因是什么?更新:0x4684abc不同于36971870,即0x234255E>>a=Point.new=>#>>a.object_id=>36971870>>a.__id__=>36971870>>"%X"%a.object_id=>"234255E" 最佳答案 inspect的默认实现调用了to_s的默认实现,它只是直接显示对象的十六进制值,如Object#to_s中所见docs(单击方法描述以显示来源)。同时,object_id实现的C源

ruby - 调用/应用 lambda 与函数调用 - Ruby 中的语法不同。为什么?

我对Ruby有点陌生,仍在努力理解一些语言设计原则。如果我做对了,Ruby中的lambda表达式调用必须使用方括号,而“常规”函数调用则使用“常规”/圆括号。语法不同是不是有什么特殊原因?或者,换句话说,(为什么)调用者应该知道他们是调用函数还是应用lambda表达式? 最佳答案 常规的Ruby方法调用使用()而不是用于block的花括号。如果您不喜欢[]来调用lambda,您始终可以使用call方法。例子:>>by_two=lambda{|x|x*2}#=>#>>by_two[5]#=>10>>by_two.call(5)#=>1

ruby - 减少哈希值

我对reduce的语法有疑问。我有以下格式的散列:H={"Key1"=>1,"Key2"=>2}我想使用reduce求此函数中值的总和。类似的东西H.reduce(0){|memo,elem|memo+=elem}我知道这是错误的。我不明白如何使elem成为散列的值。 最佳答案 您可以通过将值分成2个变量来使elem包含该值:H.reduce(0){|memo,(key,val)|memo+val} 关于ruby-减少哈希值,我们在StackOverflow上找到一个类似的问题: